跳到主要内容

kubernetes 标签 Label 的使用

Label 标签是啥?

Label 是 kubernetes 的一个重要概念。它的作用就是在资源上添加标识,用来对它们进行区分和选择。

  • 一个 Label 会以 key/value 键值对的形式附加到各种对象上,如 Node、Pod、Service 等。
  • 一个资源对象可以定义任意数量的 Label,同一个 Label 也可以被添加到任意数量的资源对象上去。
  • Label 通常在资源对象定义时确定,当然也可以在对象创建后动态的添加或删除。

可以通过 Label 实现资源的多纬度分组,以便灵活、方便地进行资源分配、调度、配置和部署等管理工作。

一些常用的 Label 标签示例如下:

版本标签:"version":"release", "version":"stable"......
环境标签:"environment":"dev","environment":"test","environment":"pro"
架构标签:"tier":"frontend","tier":"backend"

Label Selector 标签选择器

标签定义完毕之后,还要考虑到标签的选择,这就要使用到 Label Selector,即 Label Selector 用于查询和筛选拥有某些标签的资源对象

当前有两种 Label Selector:

1、基于等式的 Label Selector

name = slave: 选择所有包含 Label 中 key="name" 且 value="slave" 的对象 env != production: 选择所有包括 Label 中的 key="env" 且 value 不等于 "production" 的对象

# 列出包含 env 标签的所有 pod, 无论其值如何
$ kubectl get po -l env

# 同样列出没有 env 标签的 pod:
$ kubectl get po -l '!env'

注意确保使用单引号来包裹 !env,这样 bash shell 才不会解释感叹号

2、基于集合的 Label Selector

name in (master, slave) 选择 key="name" 且 value="master" 或 "slave" 的对象 name not in (frontend) 选择 key="name" 且 value 不等于 "frontend" 的对象

标签的选择条件可以使用多个,将多个 Label Selector 进行组合,使用逗号 , 进行分隔即可。

例如:

name=slave, env!=production
name not in (frontend), env!=production

命令方式打标签

为 pod 资源打标签

kubectl label pod nginx-pod version=1.0 -n dev

为 pod 资源更新标签

kubectl label pod nginx-pod version=2.0 -n dev --overwrite

查看标签

$ kubectl get pod nginx-pod  -n dev --show-labels
NAME READY STATUS RESTARTS AGE LABELS
nginx-pod 1/1 Running 0 10m version=2.0

筛选标签

$ kubectl get pod -n dev -l version=2.0  --show-labels

$ kubectl get pod -n dev -l version!=2.0 --show-labels

删除标签

kubectl label pod nginx-pod version- -n dev

配置方式打标签

apiVersion: v1
kind: Pod
metadata:
name: nginx
namespace: dev
labels:
version: "3.0"
env: "test"
spec:
containers:
- image: nginx:latest
name: pod
ports:
- name: nginx-port
containerPort: 80
protocol: TCP

然后就可以执行对应的更新命令了

kubectl apply -f pod-nginx.yaml

将 pod 调度到特定节点

假设我们想部署一个需要 GPU 来执行其工作的新 pod。为了让调度器只在提供适当 GPU 的节点中进行选择,我们需要在 pod 的 YAML 文件中添加一个节点选择器。

只是在 spec 部分添加了一个 nodeSelector 字段。当我们创建该 pod 时,调度器将只在包含标签 gpu=true 的节点中选择

根据标签删除 Pod

$ kubectl delete po -l creation_method=manual